package com.ops.repository;

import com.ops.entity.Hospital;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;
import java.util.Optional;

/**
 * 医院数据访问接口
 */
@Repository
public interface HospitalRepository extends JpaRepository<Hospital, Long> {
    /**
     * 根据医院ID查询医院信息
     * @param hospitalId 医院ID
     * @return 医院信息
     */
    Optional<Hospital> findByHospitalId(String hospitalId);

    /**
     * 检查医院ID是否存在
     * @param hospitalId 医院ID
     * @return 是否存在
     */
    boolean existsByHospitalId(String hospitalId);

    /**
     * 查询所有医院信息，按医院名称升序排序
     * @return 医院信息列表
     */
    List<Hospital> findAllByOrderByHospitalNameAsc();

    /**
     * 根据医院ID删除医院信息
     * @param hospitalId 医院ID
     */
    void deleteByHospitalId(String hospitalId);

    /**
     * 根据医院ID删除医院信息（使用JPQL查询）
     * @param hospitalId 医院ID
     */
    @Transactional
    @Modifying
    @Query("DELETE FROM Hospital h WHERE h.hospitalId = :hospitalId")
    void deleteByHospitalIdQuery(@Param("hospitalId") String hospitalId);
}